mysql从一张表中取出数据插入到另一张表详细操作过程

您所在的位置:网站首页 东西我都装好了 从一张桌到两张桌的英文翻译 mysql从一张表中取出数据插入到另一张表详细操作过程

mysql从一张表中取出数据插入到另一张表详细操作过程

2024-07-05 08:38| 来源: 网络整理| 查看: 265

最近有这样一个需求,原来的订单表wp_order设计不合理,原来的订单表没有订单详表,只有一张主表。现在是要重构订单表,原来的order表要废除,分为订单主表wp_order_master和订单详表wp_order_detail,需要把原来的wp_order中的数据拆分后插入这两张表。

我这里总结有3种mysql语句方式,分别是: 以下表1为目标表,表2为原表

表结构一样 insert into 表1select * from 表2

这个方式说白了就跟复制一样,要求2张表的所有字段一致,否则报错。

表结构不一样 insert into 表1 (列名1,列名2,列名3) select 列1,列2,列3 from 表2

这种也不能说是表结构不一样,其实就是有选择性的从表2取出数据对应表1字段插入。

只从另外一个表取部分字段 insert into 表1 (列名1,列名2,列名3) values(列1,列2,(select 列3 from 表2));

这种方式适用的情况是,在从表2取出部分字段数据的同时,表1有新的字段也需要数据,相当于第2种方式的升级版。

我这里采用第2种方式:

INSERT INTO wp_order_master (id,order_number,order_code,uid,cTime,pay_time,total_price,is_pay, alipay_price,wechat_price,balance_price,cash_price,union_price,active_id,active_price,coupon_id,coupon_price, integral_num,integral_price,erase_price,use_packet_id,order_from) SELECT id,order_number,order_code,uid,cTime,pay_time,total_price,is_pay, alipay_price,wechat_price,balance_price,cash_price,union_price,active_id,active_price,coupon_id,coupon_price, integral_num,integral_price,erase_price,use_packet_id,order_from FROM wp_order WHERE id BETWEEN 10 AND 20;

因为数据较多,在select的where后面加了条件,先少量测试确保数据能正确被拆分。

下面该把原order表内的商品信息拆分出来存入新的order_detail表内

原order表内把不同产品id各占一列,感觉不合理 在这里插入图片描述 现在的设计是order_detail表内是产品id在一列product_id,利用一个order_type(订单分类来区分)。构造出下面的拆分组装新数据的sql语句:

,在插入之前先单独把后面字段值部分的sql语句拿出来,测试看是否能得到想要插入的数据。

SELECT id,order_type, ( CASE WHEN course_id'0' THEN course_id WHEN personal_course_id'0' THEN personal_course_id WHEN camp_id'0' THEN camp_id WHEN course_packet_id '0' THEN course_packet_id WHEN vip_id'0' THEN vip_id WHEN recharge_id'0' THEN recharge_id ELSE 0 END ) as product_id, goods_title,total_price unit_price,total_price subtotal,sales_id,coach_id,refund_time,refund_price FROM wp_order WHERE id BETWEEN 10 AND 20;

运行后完美得到了想要的数据 在这里插入图片描述 完整插入新表sql语句:

-- 把数据分拆到order_detail INSERT INTO wp_order_detail (order_id,order_type,product_id,product_title,unit_price,subtotal,sales_id,coach_id,refund_time,refund_price) SELECT id,order_type, ( CASE WHEN course_id'0' THEN course_id WHEN personal_course_id'0' THEN personal_course_id WHEN camp_id'0' THEN camp_id WHEN course_packet_id '0' THEN course_packet_id WHEN vip_id'0' THEN vip_id WHEN recharge_id'0' THEN recharge_id ELSE 0 END ) as product_id, goods_title,total_price unit_price,total_price subtotal,sales_id,coach_id,refund_time,refund_price FROM wp_order WHERE id BETWEEN 10 AND 20;

运行结果完美: 在这里插入图片描述 这下就可以把order_master和order_detail两张表清空

-- 清空order_master TRUNCATE TABLE wp_order_master;

取消上面操作中select中where后的条件,一次性全部拆分重组插入数据,如果数据量太大,可以考虑加条件每次比如插入1000条。



【本文地址】


今日新闻


推荐新闻


CopyRight 2018-2019 办公设备维修网 版权所有 豫ICP备15022753号-3